<!DOCTYPE html>
<html lang="en">
<head>
    <meta charset="UTF-8">
    <meta name="viewport" content="width=device-width, initial-scale=1">
    <title>webdoc</title>
    <link rel="stylesheet" type="text/css" href="../static/css/main.css">
</head>
<body>
<div class="nav">
    <div class="logo">
        
            webdoc
        
    </div>
<ul><li><a href="../index.html">0.Async</a></li><li><a href="../html/0.editor.html">0.editor</a></li><li><a href="../html/0.module.html">0.module</a></li><li><a href="../html/1.ES2015.html">1.ES2015</a></li><li><a href="../html/2.Promise.html">2.Promise</a></li><li><a href="../html/3.Node.html">3.Node</a></li><li><a href="../html/4.NodeInstall.html">4.NodeInstall</a></li><li><a href="../html/5.REPL.html">5.REPL</a></li><li><a href="../html/6.NodeCore.html">6.NodeCore</a></li><li><a href="../html/7.module&NPM.html">7.module&NPM</a></li><li><a href="../html/8.Encoding.html">8.Encoding</a></li><li><a href="../html/9.Buffer.html">9.Buffer</a></li><li><a href="../html/10.fs.html">10.fs</a></li><li><a href="../html/11.Stream-1.html">11.Stream-1</a></li><li><a href="../html/11.Stream-2.html">11.Stream-2</a></li><li><a href="../html/11.Stream-3.html">11.Stream-3</a></li><li><a href="../html/11.Stream-4.html">11.Stream-4</a></li><li><a href="../html/12-Network-2.html">12-Network-2</a></li><li><a href="../html/12.NetWork-3.html">12.NetWork-3</a></li><li><a href="../html/12.Network-1.html">12.Network-1</a></li><li><a href="../html/13.tcp.html">13.tcp</a></li><li><a href="../html/14.http-1.html">14.http-1</a></li><li><a href="../html/14.http-2.html">14.http-2</a></li><li><a href="../html/15.compress.html">15.compress</a></li><li><a href="../html/16.crypto.html">16.crypto</a></li><li><a href="../html/17.process.html">17.process</a></li><li><a href="../html/18.yargs.html">18.yargs</a></li><li><a href="../html/19.cache.html">19.cache</a></li><li><a href="../html/20.action.html">20.action</a></li><li><a href="../html/21.https.html">21.https</a></li><li><a href="../html/22.cookie.html">22.cookie</a></li><li><a href="../html/23.session.html">23.session</a></li><li><a href="../html/24.express-1.html">24.express-1</a></li><li><a href="../html/24.express-2.html">24.express-2</a></li><li><a href="../html/24.express-3.html">24.express-3</a></li><li><a href="../html/24.express-4.html">24.express-4</a></li><li><a href="../html/25.koa-1.html">25.koa-1</a></li><li><a href="../html/26.webpack-1-basic.html">26.webpack-1-basic</a></li><li><a href="../html/26.webpack-2-optimize.html">26.webpack-2-optimize</a></li><li><a href="../html/26.webpack-3.tapable.html">26.webpack-3.tapable</a></li><li><a href="../html/26.webpack-4-AST.html">26.webpack-4-AST</a></li><li><a href="../html/26.webpack-5-source.html">26.webpack-5-source</a></li><li><a href="../html/26.webpack-6-loader.html">26.webpack-6-loader</a></li><li><a href="../html/26.webpack-7-plugin.html">26.webpack-7-plugin</a></li><li><a href="../html/26.webpack-8-hand.html">26.webpack-8-hand</a></li><li><a href="../html/27.react-1.html">27.react-1</a></li><li><a href="../html/27.react-2.html">27.react-2</a></li><li><a href="../html/27.react-3.html">27.react-3</a></li><li><a href="../html/27.react-4-immutable.html">27.react-4-immutable</a></li><li><a href="../html/27.react-5-react-dom-diff.html">27.react-5-react-dom-diff</a></li><li><a href="../html/27.react-6.html">27.react-6</a></li><li><a href="../html/28.react-mobx.html">28.react-mobx</a></li><li><a href="../html/28.redux-0.html">28.redux-0</a></li><li><a href="../html/28.redux-1.html">28.redux-1</a></li><li><a href="../html/28.redux-2-中间件.html">28.redux-2-中间件</a></li><li><a href="../html/28.redux-3-saga.html">28.redux-3-saga</a></li><li><a href="../html/28.redux-jwt-back.html">28.redux-jwt-back</a></li><li><a href="../html/28.redux-jwt-front.html">28.redux-jwt-front</a></li><li><a href="../html/29.mongodb-1.html">29.mongodb-1</a></li><li><a href="../html/29.mongodb-2.html">29.mongodb-2</a></li><li class="active"><a href="../html/29.mongodb-3.html">29.mongodb-3</a></li><li><a href="../html/29.mongodb-4.html">29.mongodb-4</a></li><li><a href="../html/29.mongodb-5.html">29.mongodb-5</a></li><li><a href="../html/29.mongodb-6.html">29.mongodb-6</a></li><li><a href="../html/30.cms-1-mysql.html">30.cms-1-mysql</a></li><li><a href="../html/30.cms-2-mysql.html">30.cms-2-mysql</a></li><li><a href="../html/30.cms-3-mysql.html">30.cms-3-mysql</a></li><li><a href="../html/30.cms-4-egg.html">30.cms-4-egg</a></li><li><a href="../html/30.cms-5-api.html">30.cms-5-api</a></li><li><a href="../html/30.cms-6-roadhog.html">30.cms-6-roadhog</a></li><li><a href="../html/30.cms-7-umi.html">30.cms-7-umi</a></li><li><a href="../html/30.cms-8-dva.html">30.cms-8-dva</a></li><li><a href="../html/30.cms-9-dva.html">30.cms-9-dva</a></li><li><a href="../html/30.cms-10-dva.html">30.cms-10-dva</a></li><li><a href="../html/30.cms-11-front.html">30.cms-11-front</a></li><li><a href="../html/31.cms-12-api.html">31.cms-12-api</a></li><li><a href="../html/31.cms-13-front.html">31.cms-13-front</a></li><li><a href="../html/31.cms-14-deploy.html">31.cms-14-deploy</a></li><li><a href="../html/32.ant.html">32.ant</a></li><li><a href="../html/33.redis.html">33.redis</a></li><li><a href="../html/34.unittest.html">34.unittest</a></li><li><a href="../html/35.jwt.html">35.jwt</a></li><li><a href="../html/36.websocket-1.html">36.websocket-1</a></li><li><a href="../html/36.websocket-2.html">36.websocket-2</a></li><li><a href="../html/38.chat-api-1.html">38.chat-api-1</a></li><li><a href="../html/38.chat-api-2.html">38.chat-api-2</a></li><li><a href="../html/38.chat-3.html">38.chat-3</a></li><li><a href="../html/38.chat-api-3.html">38.chat-api-3</a></li><li><a href="../html/38.chat.html">38.chat</a></li><li><a href="../html/38.chat2.html">38.chat2</a></li><li><a href="../html/38.chat2.html">38.chat2</a></li><li><a href="../html/39.crawl-0.html">39.crawl-0</a></li><li><a href="../html/39.crawl-1.html">39.crawl-1</a></li><li><a href="../html/39.crawl-2.html">39.crawl-2</a></li><li><a href="../html/40.deploy.html">40.deploy</a></li><li><a href="../html/41.safe.html">41.safe</a></li><li><a href="../html/42.test.html">42.test</a></li><li><a href="../html/43.nginx.html">43.nginx</a></li><li><a href="../html/44.enzyme.html">44.enzyme</a></li><li><a href="../html/45.docker.html">45.docker</a></li><li><a href="../html/46.elastic.html">46.elastic</a></li><li><a href="../html/47.oauth.html">47.oauth</a></li><li><a href="../html/48.wxpay.html">48.wxpay</a></li><li><a href="../html/49.nunjucks.html">49.nunjucks</a></li><li><a href="../html/50.ketang.html">50.ketang</a></li><li><a href="../html/index.html">index</a></li><li><a href="../html/51.typescript.html">51.typescript</a></li><li><a href="../html/52.UML.html">52.UML</a></li><li><a href="../html/53.design.html">53.design</a></li><li><a href="../html/index.html">index</a></li></ul></div>


<div class="warpper">

    <div class="page-toc">
        <ul><li><a href="#t01. 索引">1. 索引</a></li><li><a href="#t12 建立索引">2 建立索引</a><ul><li><a href="#t22.1 插入数据">2.1 插入数据</a></li><li><a href="#t32.1.2 创建匿名索引">2.1.2 创建匿名索引</a></li><li><a href="#t42.1.3  创建命名索引">2.1.3  创建命名索引</a></li><li><a href="#t52.1.4 分析索引的执行过程">2.1.4 分析索引的执行过程</a></li><li><a href="#t62.1.5 指定使用的索引">2.1.5 指定使用的索引</a></li><li><a href="#t72.1.6 创建唯一索引并删除重复记录">2.1.6 创建唯一索引并删除重复记录</a></li><li><a href="#t82.1.7  删除索引">2.1.7  删除索引</a></li><li><a href="#t92.1.8   在后台创建索引">2.1.8   在后台创建索引</a></li><li><a href="#t102.1.9   建立多键索引">2.1.9   建立多键索引</a></li><li><a href="#t112.1.10 复合索引">2.1.10 复合索引</a></li><li><a href="#t122.1.11 过期索引">2.1.11 过期索引</a></li><li><a href="#t132.1.12 全文索引">2.1.12 全文索引</a></li></ul></li><li><a href="#t142.2 二维索引">2.2 二维索引</a><ul><li><a href="#t152.2.1 创建2D索引">2.2.1 创建2D索引</a></li><li><a href="#t162.2.2 查询出距离点()最近的3个点">2.2.2 查询出距离点()最近的3个点</a></li><li><a href="#t172.2.3 查询以点(50,50)和点(190,190)为对角线的正方形中的所有的点">2.2.3 查询以点(50,50)和点(190,190)为对角线的正方形中的所有的点</a></li><li><a href="#t182.2.4 查出以圆心为为半径为规则下圆心面积中的点">2.2.4 查出以圆心为为半径为规则下圆心面积中的点</a></li><li><a href="#t192.2.5  索引使用的注意事项">2.2.5  索引使用的注意事项</a></li></ul></li><li><a href="#t20附录">附录</a><ul><li><a href="#t21queryPlanner分析">queryPlanner分析</a></li><li><a href="#t22对executionStats返回逐层分析">对executionStats返回逐层分析</a></li></ul></li></ul>
    </div>
    
    <div class="content markdown-body">
        <h2 id="t01. &#x7D22;&#x5F15;">1. &#x7D22;&#x5F15; <a href="#t01. &#x7D22;&#x5F15;"> # </a></h2>
<ul>
<li>&#x7D22;&#x5F15;&#x901A;&#x5E38;&#x80FD;&#x591F;&#x6781;&#x5927;&#x7684;&#x63D0;&#x9AD8;&#x67E5;&#x8BE2;&#x7684;&#x6548;&#x7387;&#xFF0C;&#x5982;&#x679C;&#x6CA1;&#x6709;&#x7D22;&#x5F15;&#xFF0C;MongoDB&#x5728;&#x8BFB;&#x53D6;&#x6570;&#x636E;&#x65F6;&#x5FC5;&#x987B;&#x626B;&#x63CF;&#x96C6;&#x5408;&#x4E2D;&#x7684;&#x6BCF;&#x4E2A;&#x6587;&#x4EF6;&#x5E76;&#x9009;&#x53D6;&#x90A3;&#x4E9B;&#x7B26;&#x5408;&#x67E5;&#x8BE2;&#x6761;&#x4EF6;&#x7684;&#x8BB0;&#x5F55;&#x3002;</li>
<li>&#x8FD9;&#x79CD;&#x626B;&#x63CF;&#x5168;&#x96C6;&#x5408;&#x7684;&#x67E5;&#x8BE2;&#x6548;&#x7387;&#x662F;&#x975E;&#x5E38;&#x4F4E;&#x7684;&#xFF0C;&#x7279;&#x522B;&#x5728;&#x5904;&#x7406;&#x5927;&#x91CF;&#x7684;&#x6570;&#x636E;&#x65F6;&#xFF0C;&#x67E5;&#x8BE2;&#x53EF;&#x4EE5;&#x8981;&#x82B1;&#x8D39;&#x51E0;&#x5341;&#x79D2;&#x751A;&#x81F3;&#x51E0;&#x5206;&#x949F;&#xFF0C;&#x8FD9;&#x5BF9;&#x7F51;&#x7AD9;&#x7684;&#x6027;&#x80FD;&#x662F;&#x975E;&#x5E38;&#x81F4;&#x547D;&#x7684;&#x3002;</li>
<li>&#x7D22;&#x5F15;&#x662F;&#x7279;&#x6B8A;&#x7684;&#x6570;&#x636E;&#x7ED3;&#x6784;&#xFF0C;&#x7D22;&#x5F15;&#x5B58;&#x50A8;&#x5728;&#x4E00;&#x4E2A;&#x6613;&#x4E8E;&#x904D;&#x5386;&#x8BFB;&#x53D6;&#x7684;&#x6570;&#x636E;&#x96C6;&#x5408;&#x4E2D;&#xFF0C;&#x7D22;&#x5F15;&#x662F;&#x5BF9;&#x6570;&#x636E;&#x5E93;&#x8868;&#x4E2D;&#x4E00;&#x5217;&#x6216;&#x591A;&#x5217;&#x7684;&#x503C;&#x8FDB;&#x884C;&#x6392;&#x5E8F;&#x7684;&#x4E00;&#x79CD;&#x7ED3;&#x6784;</li>
</ul>
<p><img src="http://img.zhufengpeixun.cn/mongoindex.png" alt="mongoindex"></p>
<ul>
<li>&#x7279;&#x6B8A;&#x7684;&#x6570;&#x636E;&#x7ED3;&#x6784;&#xFF0C;&#x6309;&#x987A;&#x5E8F;&#x4FDD;&#x5B58;&#x6587;&#x6863;&#x4E2D;&#x7684;&#x4E00;&#x4E2A;&#x6216;&#x591A;&#x4E2A;&#x5B57;&#x6BB5;</li>
<li>&#x4F7F;&#x7528;&#x7D22;&#x5F15;&#xFF0C;&#x65B9;&#x4FBF;&#x8303;&#x56F4;&#x67E5;&#x8BE2;&#x548C;&#x5339;&#x914D;&#x67E5;&#x8BE2;&#x3002;</li>
</ul>
<h2 id="t12 &#x5EFA;&#x7ACB;&#x7D22;&#x5F15;">2 &#x5EFA;&#x7ACB;&#x7D22;&#x5F15; <a href="#t12 &#x5EFA;&#x7ACB;&#x7D22;&#x5F15;"> # </a></h2>
<h3 id="t22.1 &#x63D2;&#x5165;&#x6570;&#x636E;">2.1 &#x63D2;&#x5165;&#x6570;&#x636E; <a href="#t22.1 &#x63D2;&#x5165;&#x6570;&#x636E;"> # </a></h3>
<pre><code class="lang-js"><span class="hljs-keyword">var</span> students = [];
<span class="hljs-keyword">for</span>(<span class="hljs-keyword">var</span> i=<span class="hljs-number">1</span>;i&lt;=<span class="hljs-number">300000</span>;i++){
   students.push({<span class="hljs-attr">name</span>:<span class="hljs-string">&apos;zfpx&apos;</span>+i,<span class="hljs-attr">age</span>:i,<span class="hljs-attr">random</span>:i});
}
 db.students.insert(students);
db.students.find({<span class="hljs-attr">age</span>:<span class="hljs-number">299999</span>}).explain(<span class="hljs-literal">true</span>);<span class="hljs-comment">// &quot;executionTimeMillis&quot; : 245,</span>
</code></pre>
<h3 id="t32.1.2 &#x521B;&#x5EFA;&#x533F;&#x540D;&#x7D22;&#x5F15;">2.1.2 &#x521B;&#x5EFA;&#x533F;&#x540D;&#x7D22;&#x5F15; <a href="#t32.1.2 &#x521B;&#x5EFA;&#x533F;&#x540D;&#x7D22;&#x5F15;"> # </a></h3>
<pre><code class="lang-js">db.students.ensureIndex({<span class="hljs-attr">age</span>:<span class="hljs-number">1</span>});
db.students.find({<span class="hljs-attr">age</span>:<span class="hljs-number">299999</span>}).explain(<span class="hljs-literal">true</span>);<span class="hljs-comment">// &quot;executionTimeMillis&quot; : 7,</span>
</code></pre>
<h3 id="t42.1.3  &#x521B;&#x5EFA;&#x547D;&#x540D;&#x7D22;&#x5F15;">2.1.3  &#x521B;&#x5EFA;&#x547D;&#x540D;&#x7D22;&#x5F15; <a href="#t42.1.3  &#x521B;&#x5EFA;&#x547D;&#x540D;&#x7D22;&#x5F15;"> # </a></h3>
<pre><code class="lang-js">db.students.ensureIndex({<span class="hljs-attr">name</span>:<span class="hljs-number">1</span>},{<span class="hljs-attr">name</span>:<span class="hljs-string">&apos;namedIndex&apos;</span>});
db.students.getIndexes()<span class="hljs-comment">//&#x67E5;&#x770B;&#x7D22;&#x5F15;</span>
</code></pre>
<h3 id="t52.1.4 &#x5206;&#x6790;&#x7D22;&#x5F15;&#x7684;&#x6267;&#x884C;&#x8FC7;&#x7A0B;">2.1.4 &#x5206;&#x6790;&#x7D22;&#x5F15;&#x7684;&#x6267;&#x884C;&#x8FC7;&#x7A0B; <a href="#t52.1.4 &#x5206;&#x6790;&#x7D22;&#x5F15;&#x7684;&#x6267;&#x884C;&#x8FC7;&#x7A0B;"> # </a></h3>
<p>MongoDB &#x63D0;&#x4F9B;&#x4E86;&#x4E00;&#x4E2A; explain &#x547D;&#x4EE4;&#x8BA9;&#x6211;&#x4EEC;&#x83B7;&#x77E5;&#x7CFB;&#x7EDF;&#x5982;&#x4F55;&#x5904;&#x7406;&#x67E5;&#x8BE2;&#x8BF7;&#x6C42;&#x3002;&#x5229;&#x7528; explain &#x547D;&#x4EE4;&#xFF0C;&#x6211;&#x4EEC;&#x53EF;&#x4EE5;&#x5F88;&#x597D;&#x5730;&#x89C2;&#x5BDF;&#x7CFB;&#x7EDF;&#x5982;&#x4F55;&#x4F7F;&#x7528;&#x7D22;&#x5F15;&#x6765;&#x52A0;&#x5FEB;&#x68C0;&#x7D22;&#xFF0C;&#x540C;&#x65F6;&#x53EF;&#x4EE5;&#x9488;&#x5BF9;&#x6027;&#x4F18;&#x5316;&#x7D22;&#x5F15;&#x3002;</p>
<ul>
<li>cursor: &#x8FD4;&#x56DE;&#x6E38;&#x6807;&#x7C7B;&#x578B;<ul>
<li>BasicCursor&#x800C;&#x6CA1;&#x6709;&#x4F7F;&#x7528;&#x7D22;&#x5F15;&#x7684;&#x67E5;&#x8BE2;&#x5E76;&#x4E0D;&#x662F;&#x80E1;&#x4E71;&#x67E5;&#x8BE2;&#xFF0C;&#x800C;&#x662F;&#x4F7F;&#x7528;&#x4E86;&#x57FA;&#x672C;&#x6E38;&#x6807;&#xFF1A;&#xFF0C;&#x540C;&#x7406;&#xFF0C;</li>
<li>&#x4F7F;&#x7528;&#x7D22;&#x5F15;&#x7684;&#x67E5;&#x8BE2;&#x5C31;&#x662F;BtreeCursor</li>
</ul>
</li>
<li>nscanned: &#x67E5;&#x627E;&#x8FC7;&#x7684;&#x7D22;&#x5F15;&#x6761;&#x76EE;&#x7684;&#x6570;&#x91CF;</li>
<li>n: &#x8FD4;&#x56DE;&#x7684;&#x6587;&#x6863;&#x6570;&#x91CF;</li>
<li>nscannedObjects &#xFF1A;&#x6570;&#x636E;&#x5E93;&#x6309;&#x7167;&#x7D22;&#x5F15;&#x53BB;&#x78C1;&#x76D8;&#x4E0A;&#x67E5;&#x627E;&#x5B9E;&#x9645;&#x6587;&#x6863;&#x7684;&#x6B21;&#x6570;</li>
<li>millis: &#x6267;&#x884C;&#x672C;&#x6B21;&#x67E5;&#x8BE2;&#x6240;&#x82B1;&#x8D39;&#x7684;&#x65F6;&#x95F4;&#xFF0C;&#x4EE5;&#x6BEB;&#x79D2;&#x8BA1;&#x7B97;&#xFF0C;&#x8FD9;&#x4E5F;&#x662F;&#x5224;&#x65AD;&#x67E5;&#x8BE2;&#x6548;&#x7387;&#x7684;&#x4E00;&#x4E2A;&#x91CD;&#x70B9;</li>
<li>indexBounds:  &#x63CF;&#x8FF0;&#x7D22;&#x5F15;&#x7684;&#x4F7F;&#x7528;&#x60C5;&#x51B5;</li>
<li>isMultiKey:&#x662F;&#x5426;&#x4F7F;&#x7528;&#x4E86;&#x591A;&#x952E;&#x7D22;&#x5F15;</li>
<li>scanAndOrder: &#x662F;&#x5426;&#x5728;&#x5185;&#x5B58;&#x4E2D;&#x5BF9;&#x7ED3;&#x679C;&#x8FDB;&#x884C;&#x4E86;&#x6392;&#x5E8F;</li>
<li>indexOnly:&#x662F;&#x5426;&#x4EC5;&#x4EC5;&#x4F7F;&#x7528;&#x7D22;&#x5F15;&#x5B8C;&#x6210;&#x4E86;&#x672C;&#x6B21;&#x67E5;&#x8BE2;</li>
</ul>
<pre><code class="lang-js">db.students.find({<span class="hljs-attr">name</span>:<span class="hljs-string">&apos;zfpx150000&apos;</span>}).explain();
</code></pre>
<h3 id="t62.1.5 &#x6307;&#x5B9A;&#x4F7F;&#x7528;&#x7684;&#x7D22;&#x5F15;">2.1.5 &#x6307;&#x5B9A;&#x4F7F;&#x7528;&#x7684;&#x7D22;&#x5F15; <a href="#t62.1.5 &#x6307;&#x5B9A;&#x4F7F;&#x7528;&#x7684;&#x7D22;&#x5F15;"> # </a></h3>
<pre><code class="lang-js">db.students.find({<span class="hljs-attr">name</span>:<span class="hljs-string">&apos;zfpx299999&apos;</span>,<span class="hljs-attr">age</span>:<span class="hljs-number">299999</span>}).hint({<span class="hljs-attr">name</span>:<span class="hljs-number">1</span>}).explain(<span class="hljs-literal">true</span>);
</code></pre>
<h3 id="t72.1.6 &#x521B;&#x5EFA;&#x552F;&#x4E00;&#x7D22;&#x5F15;&#x5E76;&#x5220;&#x9664;&#x91CD;&#x590D;&#x8BB0;&#x5F55;">2.1.6 &#x521B;&#x5EFA;&#x552F;&#x4E00;&#x7D22;&#x5F15;&#x5E76;&#x5220;&#x9664;&#x91CD;&#x590D;&#x8BB0;&#x5F55; <a href="#t72.1.6 &#x521B;&#x5EFA;&#x552F;&#x4E00;&#x7D22;&#x5F15;&#x5E76;&#x5220;&#x9664;&#x91CD;&#x590D;&#x8BB0;&#x5F55;"> # </a></h3>
<pre><code class="lang-js">db.person.ensureIndex({ <span class="hljs-string">&quot;name&quot;</span> : <span class="hljs-number">-1</span> },{ <span class="hljs-string">&quot;name&quot;</span> : <span class="hljs-string">&quot;indexname&quot;</span>, <span class="hljs-string">&quot;unique&quot;</span> : <span class="hljs-literal">true</span>,<span class="hljs-attr">dropDups</span>:<span class="hljs-literal">true</span> })
</code></pre>
<h3 id="t82.1.7  &#x5220;&#x9664;&#x7D22;&#x5F15;">2.1.7  &#x5220;&#x9664;&#x7D22;&#x5F15; <a href="#t82.1.7  &#x5220;&#x9664;&#x7D22;&#x5F15;"> # </a></h3>
<pre><code class="lang-js">db.students.dropIndex(<span class="hljs-string">&apos;namedIndex&apos;</span>);<span class="hljs-comment">//&#x5220;&#x9664;&#x6307;&#x5B9A;&#x7684;&#x7D22;&#x5F15;</span>
db.students.dropIndex(<span class="hljs-string">&apos;*&apos;</span>);
db.runCommand({<span class="hljs-attr">dropIndexes</span>:<span class="hljs-string">&quot;students&quot;</span>,<span class="hljs-attr">index</span>:<span class="hljs-string">&quot;namedIndex&quot;</span>});<span class="hljs-comment">//&#x5220;&#x9664;&#x6240;&#x6709;&#x7684;&#x7D22;&#x5F15;</span>
</code></pre>
<h3 id="t92.1.8   &#x5728;&#x540E;&#x53F0;&#x521B;&#x5EFA;&#x7D22;&#x5F15;">2.1.8   &#x5728;&#x540E;&#x53F0;&#x521B;&#x5EFA;&#x7D22;&#x5F15; <a href="#t92.1.8   &#x5728;&#x540E;&#x53F0;&#x521B;&#x5EFA;&#x7D22;&#x5F15;"> # </a></h3>
<pre><code class="lang-js">db.students.ensureIndex({<span class="hljs-attr">name</span>:<span class="hljs-number">1</span>},{<span class="hljs-attr">name</span>:<span class="hljs-string">&apos;nameIndex&apos;</span>,<span class="hljs-attr">unique</span>:<span class="hljs-literal">true</span>,<span class="hljs-attr">background</span>:<span class="hljs-literal">true</span>});
</code></pre>
<h3 id="t102.1.9   &#x5EFA;&#x7ACB;&#x591A;&#x952E;&#x7D22;&#x5F15;">2.1.9   &#x5EFA;&#x7ACB;&#x591A;&#x952E;&#x7D22;&#x5F15; <a href="#t102.1.9   &#x5EFA;&#x7ACB;&#x591A;&#x952E;&#x7D22;&#x5F15;"> # </a></h3>
<p>mongodb&#x53EF;&#x4EE5;&#x81EA;&#x52A8;&#x5BF9;&#x6570;&#x7EC4;&#x8FDB;&#x884C;&#x7D22;&#x5F15;</p>
<pre><code class="lang-js">db.students.insert({<span class="hljs-attr">hobby</span>:[<span class="hljs-string">&apos;basketball&apos;</span>,<span class="hljs-string">&apos;football&apos;</span>,<span class="hljs-string">&apos;pingpang&apos;</span>]});
db.students.ensureIndex({<span class="hljs-attr">hobby</span>:<span class="hljs-number">1</span>});
db.students.find({<span class="hljs-attr">hobby</span>:<span class="hljs-string">&apos;football&apos;</span>},{<span class="hljs-attr">hobby</span>:<span class="hljs-number">1</span>,<span class="hljs-attr">_id</span>:<span class="hljs-number">0</span>}).explain(<span class="hljs-literal">true</span>);
</code></pre>
<h3 id="t112.1.10 &#x590D;&#x5408;&#x7D22;&#x5F15;">2.1.10 &#x590D;&#x5408;&#x7D22;&#x5F15; <a href="#t112.1.10 &#x590D;&#x5408;&#x7D22;&#x5F15;"> # </a></h3>
<p>&#x67E5;&#x8BE2;&#x7684;&#x6761;&#x4EF6;&#x4E0D;&#x6B62;&#x4E00;&#x4E2A;&#xFF0C;&#x9700;&#x8981;&#x7528;&#x590D;&#x5408;&#x7D22;&#x5F15;</p>
<pre><code class="lang-js">db.students.ensureIndex({<span class="hljs-attr">name</span>:<span class="hljs-number">1</span>,<span class="hljs-attr">age</span>:<span class="hljs-number">1</span>});
db.students.find({<span class="hljs-attr">name</span>:<span class="hljs-number">1</span>,<span class="hljs-attr">age</span>:<span class="hljs-number">2</span>},{<span class="hljs-attr">name</span>:<span class="hljs-number">1</span>,<span class="hljs-attr">age</span>:<span class="hljs-number">1</span>,<span class="hljs-attr">_id</span>:<span class="hljs-number">0</span>}).explain(<span class="hljs-literal">true</span>);
</code></pre>
<h3 id="t122.1.11 &#x8FC7;&#x671F;&#x7D22;&#x5F15;">2.1.11 &#x8FC7;&#x671F;&#x7D22;&#x5F15; <a href="#t122.1.11 &#x8FC7;&#x671F;&#x7D22;&#x5F15;"> # </a></h3>
<p>&#x5728;&#x4E00;&#x5B9A;&#x7684;&#x65F6;&#x95F4;&#x540E;&#x4F1A;&#x8FC7;&#x671F;&#xFF0C;&#x8FC7;&#x671F;&#x540E;&#x76F8;&#x5E94;&#x6570;&#x636E;&#x6570;&#x636E;&#x88AB;&#x5220;&#x9664;,&#x6BD4;&#x5982; <code>session</code>&#x3001;&#x65E5;&#x5FD7;&#x3001;&#x7F13;&#x5B58;&#x548C;&#x4E34;&#x65F6;&#x6587;&#x4EF6;</p>
<pre><code class="lang-js">db.stus.insert({<span class="hljs-attr">time</span>:<span class="hljs-keyword">new</span> <span class="hljs-built_in">Date</span>()});
db.stus.ensureIndex({<span class="hljs-attr">time</span>:<span class="hljs-number">1</span>},{<span class="hljs-attr">expireAfterSeconds</span>:<span class="hljs-number">10</span>});
db.stus.find();
</code></pre>
<ul>
<li>1.&#x7D22;&#x5F15;&#x5B57;&#x6BB5;&#x7684;&#x503C;&#x5FC5;&#x987B;Date&#x5BF9;&#x8C61;&#xFF0C;&#x4E0D;&#x80FD;&#x662F;&#x5176;&#x5B83;&#x7C7B;&#x578B;&#x6BD4;&#x5982;&#x65F6;&#x95F4;&#x6233;</li>
<li>2.&#x5220;&#x9664;&#x65F6;&#x95F4;&#x4E0D;&#x7CBE;&#x786E;&#xFF0C;&#x6BCF;60&#x79D2;&#x8DD1;&#x4E00;&#x6B21;&#x3002;&#x5220;&#x9664;&#x4E5F;&#x8981;&#x65F6;&#x95F4;&#xFF0C;&#x6240;&#x4EE5;&#x6709;&#x8BEF;&#x5DEE;&#x3002;</li>
</ul>
<h3 id="t132.1.12 &#x5168;&#x6587;&#x7D22;&#x5F15;">2.1.12 &#x5168;&#x6587;&#x7D22;&#x5F15; <a href="#t132.1.12 &#x5168;&#x6587;&#x7D22;&#x5F15;"> # </a></h3>
<p>&#x5927;&#x7BC7;&#x5E45;&#x7684;&#x6587;&#x7AE0;&#x4E2D;&#x641C;&#x7D22;&#x5173;&#x952E;&#x8BCD;,MongoDB&#x4E3A;&#x6211;&#x4EEC;&#x63D0;&#x4F9B;&#x4E86;&#x5168;&#x6587;&#x7D22;&#x5F15;</p>
<pre><code class="lang-js">db.article.insert({<span class="hljs-attr">content</span>:<span class="hljs-string">&apos;I am a gir&apos;</span>});
db.article.insert({<span class="hljs-attr">content</span>:<span class="hljs-string">&apos;I am a boy&apos;</span>});
</code></pre>
<ul>
<li>$text:&#x8868;&#x793A;&#x8981;&#x5728;&#x5168;&#x6587;&#x7D22;&#x5F15;&#x4E2D;&#x67E5;&#x4E1C;&#x897F;</li>
<li>$search:&#x540E;&#x8FB9;&#x8DDF;&#x67E5;&#x627E;&#x7684;&#x5185;&#x5BB9;, &#x9ED8;&#x8BA4;&#x5168;&#x90E8;&#x5339;&#x914D;</li>
</ul>
<pre><code class="lang-js">db.article.find({<span class="hljs-attr">$text</span>:{<span class="hljs-attr">$search</span>:<span class="hljs-string">&apos;boy&apos;</span>}});
db.article.find({<span class="hljs-attr">$text</span>:{<span class="hljs-attr">$search</span>:<span class="hljs-string">&apos;girl&apos;</span>}});
db.article.find({<span class="hljs-attr">$text</span>:{<span class="hljs-attr">$search</span>:<span class="hljs-string">&apos;boy girl&apos;</span>}});<span class="hljs-comment">//&#x591A;&#x6B21;&#x67E5;&#x627E;&#xFF0C;&#x591A;&#x4E2A;&#x5173;&#x952E;&#x5B57;&#x4E3A;&#x6216;&#x7684;&#x5173;&#x7CFB;</span>
db.article.find({<span class="hljs-attr">$text</span>:{<span class="hljs-attr">$search</span>:<span class="hljs-string">&quot;a b&quot;</span>}}); 
db.article.find({<span class="hljs-attr">$text</span>:{<span class="hljs-attr">$search</span>:<span class="hljs-string">&quot;boy -girl&quot;</span>}}); <span class="hljs-comment">// -&#x8868;&#x793A;&#x53D6;&#x6D88;</span>
db.article.find({<span class="hljs-attr">$text</span>:{<span class="hljs-attr">$search</span>:<span class="hljs-string">&quot;a \&quot;coco cola\&quot; b &quot;</span>}}); <span class="hljs-comment">//&#x652F;&#x6301;&#x8F6C;&#x4E49;&#x7B26;&#x7684;,&#x7528;\&#x659C;&#x6760;&#x6765;&#x8F6C;&#x4E49;</span>
</code></pre>
<h2 id="t142.2 &#x4E8C;&#x7EF4;&#x7D22;&#x5F15;">2.2 &#x4E8C;&#x7EF4;&#x7D22;&#x5F15; <a href="#t142.2 &#x4E8C;&#x7EF4;&#x7D22;&#x5F15;"> # </a></h2>
<p>mongodb&#x63D0;&#x4F9B;&#x5F3A;&#x5927;&#x7684;&#x7A7A;&#x95F4;&#x7D22;&#x5F15;&#x53EF;&#x4EE5;&#x67E5;&#x8BE2;&#x51FA;&#x4E00;&#x5B9A;&#x843D;&#x5730;&#x7684;&#x5730;&#x7406;&#x5750;&#x6807;</p>
<pre><code class="lang-json">[{ gis : { x : 50 , y : 30 } ];
</code></pre>
<h3 id="t152.2.1 &#x521B;&#x5EFA;2D&#x7D22;&#x5F15;">2.2.1 &#x521B;&#x5EFA;2D&#x7D22;&#x5F15; <a href="#t152.2.1 &#x521B;&#x5EFA;2D&#x7D22;&#x5F15;"> # </a></h3>
<pre><code class="lang-js">db.maps.ensureIndex({<span class="hljs-attr">gis</span>:<span class="hljs-string">&apos;2d&apos;</span>},{<span class="hljs-attr">min</span>:<span class="hljs-number">1</span>,<span class="hljs-attr">max</span>:<span class="hljs-number">3</span>});
&#x9ED8;&#x8BA4;&#x4F1A;&#x521B;&#x5EFA;&#x4E00;&#x4E2A;<span class="hljs-number">2</span>D&#x7D22;&#x5F15;
</code></pre>
<h3 id="t162.2.2 &#x67E5;&#x8BE2;&#x51FA;&#x8DDD;&#x79BB;&#x70B9;()&#x6700;&#x8FD1;&#x7684;3&#x4E2A;&#x70B9;">2.2.2 &#x67E5;&#x8BE2;&#x51FA;&#x8DDD;&#x79BB;&#x70B9;()&#x6700;&#x8FD1;&#x7684;3&#x4E2A;&#x70B9; <a href="#t162.2.2 &#x67E5;&#x8BE2;&#x51FA;&#x8DDD;&#x79BB;&#x70B9;()&#x6700;&#x8FD1;&#x7684;3&#x4E2A;&#x70B9;"> # </a></h3>
<pre><code class="lang-js">db.maps.find({<span class="hljs-attr">gis</span>:{<span class="hljs-attr">$near</span>:[<span class="hljs-number">1</span>,<span class="hljs-number">1</span>]}}).limit(<span class="hljs-number">3</span>);
</code></pre>
<h3 id="t172.2.3 &#x67E5;&#x8BE2;&#x4EE5;&#x70B9;(50,50)&#x548C;&#x70B9;(190,190)&#x4E3A;&#x5BF9;&#x89D2;&#x7EBF;&#x7684;&#x6B63;&#x65B9;&#x5F62;&#x4E2D;&#x7684;&#x6240;&#x6709;&#x7684;&#x70B9;">2.2.3 &#x67E5;&#x8BE2;&#x4EE5;&#x70B9;(50,50)&#x548C;&#x70B9;(190,190)&#x4E3A;&#x5BF9;&#x89D2;&#x7EBF;&#x7684;&#x6B63;&#x65B9;&#x5F62;&#x4E2D;&#x7684;&#x6240;&#x6709;&#x7684;&#x70B9; <a href="#t172.2.3 &#x67E5;&#x8BE2;&#x4EE5;&#x70B9;(50,50)&#x548C;&#x70B9;(190,190)&#x4E3A;&#x5BF9;&#x89D2;&#x7EBF;&#x7684;&#x6B63;&#x65B9;&#x5F62;&#x4E2D;&#x7684;&#x6240;&#x6709;&#x7684;&#x70B9;"> # </a></h3>
<pre><code class="lang-js">db.map.find({<span class="hljs-attr">gis</span>:{<span class="hljs-attr">$within</span>:{<span class="hljs-attr">$box</span>:[[<span class="hljs-number">1</span>,<span class="hljs-number">1</span>],[<span class="hljs-number">2</span>,<span class="hljs-number">2</span>]]}}},{<span class="hljs-attr">_id</span>:<span class="hljs-number">0</span>,<span class="hljs-attr">gis</span>:<span class="hljs-number">1</span>});
</code></pre>
<h3 id="t182.2.4 &#x67E5;&#x51FA;&#x4EE5;&#x5706;&#x5FC3;&#x4E3A;&#x4E3A;&#x534A;&#x5F84;&#x4E3A;&#x89C4;&#x5219;&#x4E0B;&#x5706;&#x5FC3;&#x9762;&#x79EF;&#x4E2D;&#x7684;&#x70B9;">2.2.4 &#x67E5;&#x51FA;&#x4EE5;&#x5706;&#x5FC3;&#x4E3A;&#x4E3A;&#x534A;&#x5F84;&#x4E3A;&#x89C4;&#x5219;&#x4E0B;&#x5706;&#x5FC3;&#x9762;&#x79EF;&#x4E2D;&#x7684;&#x70B9; <a href="#t182.2.4 &#x67E5;&#x51FA;&#x4EE5;&#x5706;&#x5FC3;&#x4E3A;&#x4E3A;&#x534A;&#x5F84;&#x4E3A;&#x89C4;&#x5219;&#x4E0B;&#x5706;&#x5FC3;&#x9762;&#x79EF;&#x4E2D;&#x7684;&#x70B9;"> # </a></h3>
<pre><code class="lang-js">db.maps.find({<span class="hljs-attr">gis</span>:{<span class="hljs-attr">$within</span>:{<span class="hljs-attr">$center</span>:[[<span class="hljs-number">2</span>,<span class="hljs-number">2</span>],<span class="hljs-number">1</span>]}}},{<span class="hljs-attr">_id</span>:<span class="hljs-number">0</span>,<span class="hljs-attr">gis</span>:<span class="hljs-number">1</span>});
</code></pre>
<h3 id="t192.2.5  &#x7D22;&#x5F15;&#x4F7F;&#x7528;&#x7684;&#x6CE8;&#x610F;&#x4E8B;&#x9879;">2.2.5  &#x7D22;&#x5F15;&#x4F7F;&#x7528;&#x7684;&#x6CE8;&#x610F;&#x4E8B;&#x9879; <a href="#t192.2.5  &#x7D22;&#x5F15;&#x4F7F;&#x7528;&#x7684;&#x6CE8;&#x610F;&#x4E8B;&#x9879;"> # </a></h3>
<ol>
<li>1&#x4E3A;&#x6B63;&#x5E8F; -1&#x4E3A;&#x5012;&#x5E8F;</li>
<li>&#x7D22;&#x5F15;&#x867D;&#x7136;&#x53EF;&#x4EE5;&#x63D0;&#x5347;&#x67E5;&#x8BE2;&#x6027;&#x80FD;&#xFF0C;&#x4F46;&#x4F1A;&#x964D;&#x4F4E;&#x63D2;&#x4EF6;&#x6027;&#x80FD;&#xFF0C;&#x5BF9;&#x4E8E;&#x63D2;&#x5165;&#x591A;&#x67E5;&#x8BE2;&#x5C11;&#x4E0D;&#x8981;&#x521B;&#x7D22;&#x5F15;</li>
<li>&#x6570;&#x636E;&#x91CF;&#x4E0D;&#x5927;&#x65F6;&#x4E0D;&#x9700;&#x8981;&#x4F7F;&#x7528;&#x7D22;&#x5F15;&#x3002;&#x6027;&#x80FD;&#x7684;&#x63D0;&#x5347;&#x5E76;&#x4E0D;&#x660E;&#x663E;&#xFF0C;&#x53CD;&#x800C;&#x5927;&#x5927;&#x589E;&#x52A0;&#x4E86;&#x5185;&#x5B58;&#x548C;&#x786C;&#x76D8;&#x7684;&#x6D88;&#x8017;&#x3002;</li>
<li>&#x67E5;&#x8BE2;&#x6570;&#x636E;&#x8D85;&#x8FC7;&#x8868;&#x6570;&#x636E;&#x91CF;30%&#x65F6;&#xFF0C;&#x4E0D;&#x8981;&#x4F7F;&#x7528;&#x7D22;&#x5F15;&#x5B57;&#x6BB5;&#x67E5;&#x8BE2;</li>
<li>&#x6392;&#x5E8F;&#x5DE5;&#x4F5C;&#x7684;&#x65F6;&#x5019;&#x53EF;&#x4EE5;&#x5EFA;&#x7ACB;&#x7D22;&#x5F15;&#x4EE5;&#x63D0;&#x9AD8;&#x6392;&#x5E8F;&#x901F;&#x5EA6;</li>
<li>&#x6570;&#x5B57;&#x7D22;&#x5F15;&#xFF0C;&#x8981;&#x6BD4;&#x5B57;&#x7B26;&#x4E32;&#x7D22;&#x5F15;&#x5FEB;&#x7684;&#x591A;</li>
</ol>
<h2 id="t20&#x9644;&#x5F55;">&#x9644;&#x5F55; <a href="#t20&#x9644;&#x5F55;"> # </a></h2>
<h3 id="t21queryPlanner&#x5206;&#x6790;">queryPlanner&#x5206;&#x6790; <a href="#t21queryPlanner&#x5206;&#x6790;"> # </a></h3>
<ul>
<li>queryPlanner: queryPlanner&#x7684;&#x8FD4;&#x56DE;<ul>
<li>queryPlanner.namespace:&#x8BE5;&#x503C;&#x8FD4;&#x56DE;&#x7684;&#x662F;&#x8BE5;query&#x6240;&#x67E5;&#x8BE2;&#x7684;&#x8868;</li>
<li>queryPlanner.indexFilterSet:&#x9488;&#x5BF9;&#x8BE5;query&#x662F;&#x5426;&#x6709;indexfilter</li>
<li>queryPlanner.winningPlan:&#x67E5;&#x8BE2;&#x4F18;&#x5316;&#x5668;&#x9488;&#x5BF9;&#x8BE5;query&#x6240;&#x8FD4;&#x56DE;&#x7684;&#x6700;&#x4F18;&#x6267;&#x884C;&#x8BA1;&#x5212;&#x7684;&#x8BE6;&#x7EC6;&#x5185;&#x5BB9;&#x3002;</li>
<li>queryPlanner.winningPlan.stage:&#x6700;&#x4F18;&#x6267;&#x884C;&#x8BA1;&#x5212;&#x7684;stage&#xFF0C;&#x8FD9;&#x91CC;&#x8FD4;&#x56DE;&#x662F;FETCH&#xFF0C;&#x53EF;&#x4EE5;&#x7406;&#x89E3;&#x4E3A;&#x901A;&#x8FC7;&#x8FD4;&#x56DE;&#x7684;index&#x4F4D;&#x7F6E;&#x53BB;&#x68C0;&#x7D22;&#x5177;&#x4F53;&#x7684;&#x6587;&#x6863;&#xFF08;stage&#x6709;&#x6570;&#x4E2A;&#x6A21;&#x5F0F;&#xFF0C;&#x5C06;&#x5728;&#x540E;&#x6587;&#x4E2D;&#x8FDB;&#x884C;&#x8BE6;&#x89E3;&#xFF09;&#x3002;</li>
<li>queryPlanner.winningPlan.inputStage:&#x7528;&#x6765;&#x63CF;&#x8FF0;&#x5B50;stage&#xFF0C;&#x5E76;&#x4E14;&#x4E3A;&#x5176;&#x7236;stage&#x63D0;&#x4F9B;&#x6587;&#x6863;&#x548C;&#x7D22;&#x5F15;&#x5173;&#x952E;&#x5B57;&#x3002;</li>
<li>queryPlanner.winningPlan.stage&#x7684;child stage&#xFF0C;&#x6B64;&#x5904;&#x662F;IXSCAN&#xFF0C;&#x8868;&#x793A;&#x8FDB;&#x884C;&#x7684;&#x662F;index scanning&#x3002;</li>
<li>queryPlanner.winningPlan.keyPattern:&#x6240;&#x626B;&#x63CF;&#x7684;index&#x5185;&#x5BB9;&#xFF0C;&#x6B64;&#x5904;&#x662F;did:1,status:1,modify_time: -1&#x4E0E;scid : 1</li>
<li>queryPlanner.winningPlan.indexName&#xFF1A;winning plan&#x6240;&#x9009;&#x7528;&#x7684;index&#x3002;</li>
<li>queryPlanner.winningPlan.isMultiKey&#x662F;&#x5426;&#x662F;Multikey&#xFF0C;&#x6B64;&#x5904;&#x8FD4;&#x56DE;&#x662F;false&#xFF0C;&#x5982;&#x679C;&#x7D22;&#x5F15;&#x5EFA;&#x7ACB;&#x5728;array&#x4E0A;&#xFF0C;&#x6B64;&#x5904;&#x5C06;&#x662F;true&#x3002;</li>
<li>queryPlanner.winningPlan.direction&#xFF1A;&#x6B64;query&#x7684;&#x67E5;&#x8BE2;&#x987A;&#x5E8F;&#xFF0C;&#x6B64;&#x5904;&#x662F;forward&#xFF0C;&#x5982;&#x679C;&#x7528;&#x4E86;.sort({modify_time:-1})&#x5C06;&#x663E;&#x793A;backward&#x3002;</li>
<li>queryPlanner.winningPlan.indexBounds:winningplan&#x6240;&#x626B;&#x63CF;&#x7684;&#x7D22;&#x5F15;&#x8303;&#x56F4;,&#x5982;&#x679C;&#x6CA1;&#x6709;&#x5236;&#x5B9A;&#x8303;&#x56F4;&#x5C31;&#x662F;[MaxKey, MinKey]&#xFF0C;&#x8FD9;&#x4E3B;&#x8981;&#x662F;&#x76F4;&#x63A5;&#x5B9A;&#x4F4D;&#x5230;mongodb&#x7684;chunck&#x4E2D;&#x53BB;&#x67E5;&#x627E;&#x6570;&#x636E;&#xFF0C;&#x52A0;&#x5FEB;&#x6570;&#x636E;&#x8BFB;&#x53D6;&#x3002;</li>
<li>queryPlanner.rejectedPlans&#xFF1A;&#x5176;&#x4ED6;&#x6267;&#x884C;&#x8BA1;&#x5212;&#xFF08;&#x975E;&#x6700;&#x4F18;&#x800C;&#x88AB;&#x67E5;&#x8BE2;&#x4F18;&#x5316;&#x5668;reject&#x7684;&#xFF09;&#x7684;&#x8BE6;&#x7EC6;&#x8FD4;&#x56DE;&#xFF0C;&#x5176;&#x4E2D;&#x5177;&#x4F53;&#x4FE1;&#x606F;&#x4E0E;winningPlan&#x7684;&#x8FD4;&#x56DE;&#x4E2D;&#x610F;&#x4E49;&#x76F8;&#x540C;&#xFF0C;&#x6545;&#x4E0D;&#x5728;&#x6B64;&#x8D58;&#x8FF0;&#x3002;</li>
</ul>
</li>
</ul>
<h3 id="t22&#x5BF9;executionStats&#x8FD4;&#x56DE;&#x9010;&#x5C42;&#x5206;&#x6790;">&#x5BF9;executionStats&#x8FD4;&#x56DE;&#x9010;&#x5C42;&#x5206;&#x6790; <a href="#t22&#x5BF9;executionStats&#x8FD4;&#x56DE;&#x9010;&#x5C42;&#x5206;&#x6790;"> # </a></h3>
<ul>
<li>&#x7B2C;&#x4E00;&#x5C42;&#xFF0C;executionTimeMillis</li>
<li>&#x6700;&#x4E3A;&#x76F4;&#x89C2;explain&#x8FD4;&#x56DE;&#x503C;&#x662F;executionTimeMillis&#x503C;&#xFF0C;&#x6307;&#x7684;&#x662F;&#x6211;&#x4EEC;&#x8FD9;&#x6761;&#x8BED;&#x53E5;&#x7684;&#x6267;&#x884C;&#x65F6;&#x95F4;&#xFF0C;&#x8FD9;&#x4E2A;&#x503C;&#x5F53;&#x7136;&#x662F;&#x5E0C;&#x671B;&#x8D8A;&#x5C11;&#x8D8A;&#x597D;&#x3002;</li>
<li>&#x5176;&#x4E2D;&#x6709;3&#x4E2A;executionTimeMillis&#xFF0C;&#x5206;&#x522B;&#x662F;&#xFF1A;<ul>
<li>executionStats.executionTimeMillis &#x8BE5;query&#x7684;&#x6574;&#x4F53;&#x67E5;&#x8BE2;&#x65F6;&#x95F4;&#x3002;</li>
<li>executionStats.executionStages.executionTimeMillisEstimate</li>
<li>&#x8BE5;&#x67E5;&#x8BE2;&#x6839;&#x636E;index&#x53BB;&#x68C0;&#x7D22;document&#x83B7;&#x5F97;2001&#x6761;&#x6570;&#x636E;&#x7684;&#x65F6;&#x95F4;&#x3002;</li>
<li>executionStats.executionStages.inputStage.executionTimeMillisEstimate</li>
<li>&#x8BE5;&#x67E5;&#x8BE2;&#x626B;&#x63CF;2001&#x884C;index&#x6240;&#x7528;&#x65F6;&#x95F4;&#x3002;</li>
</ul>
</li>
<li>&#x7B2C;&#x4E8C;&#x5C42;&#xFF0C;index&#x4E0E;document&#x626B;&#x63CF;&#x6570;&#x4E0E;&#x67E5;&#x8BE2;&#x8FD4;&#x56DE;&#x6761;&#x76EE;&#x6570;
&#x8FD9;&#x4E2A;&#x4E3B;&#x8981;&#x8BA8;&#x8BBA;3&#x4E2A;&#x8FD4;&#x56DE;&#x9879;&#xFF0C;nReturned&#x3001;totalKeysExamined&#x3001;totalDocsExamined&#xFF0C;&#x5206;&#x522B;&#x4EE3;&#x8868;&#x8BE5;&#x6761;&#x67E5;&#x8BE2;&#x8FD4;&#x56DE;&#x7684;&#x6761;&#x76EE;&#x3001;&#x7D22;&#x5F15;&#x626B;&#x63CF;&#x6761;&#x76EE;&#x3001;&#x6587;&#x6863;&#x626B;&#x63CF;&#x6761;&#x76EE;&#x3002;
&#x8FD9;&#x4E9B;&#x90FD;&#x662F;&#x76F4;&#x89C2;&#x5730;&#x5F71;&#x54CD;&#x5230;executionTimeMillis&#xFF0C;&#x6211;&#x4EEC;&#x9700;&#x8981;&#x626B;&#x63CF;&#x7684;&#x8D8A;&#x5C11;&#x901F;&#x5EA6;&#x8D8A;&#x5FEB;&#x3002;
&#x5BF9;&#x4E8E;&#x4E00;&#x4E2A;&#x67E5;&#x8BE2;&#xFF0C;&#x6211;&#x4EEC;&#x6700;&#x7406;&#x60F3;&#x7684;&#x72B6;&#x6001;&#x662F;&#xFF1A;nReturned=totalKeysExamined=totalDocsExamined</li>
<li>&#x7B2C;&#x4E09;&#x5C42;&#xFF0C;stage&#x72B6;&#x6001;&#x5206;&#x6790;
&#x90A3;&#x4E48;&#x53C8;&#x662F;&#x4EC0;&#x4E48;&#x5F71;&#x54CD;&#x5230;&#x4E86;totalKeysExamined&#x548C;totalDocsExamined&#xFF1F;&#x662F;stage&#x7684;&#x7C7B;&#x578B;&#x3002;&#x7C7B;&#x578B;&#x5217;&#x4E3E;&#x5982;&#x4E0B;&#xFF1A;</li>
<li>COLLSCAN&#xFF1A;&#x5168;&#x8868;&#x626B;&#x63CF;</li>
<li>IXSCAN&#xFF1A;&#x7D22;&#x5F15;&#x626B;&#x63CF;</li>
<li>FETCH&#xFF1A;&#x6839;&#x636E;&#x7D22;&#x5F15;&#x53BB;&#x68C0;&#x7D22;&#x6307;&#x5B9A;document</li>
<li>SHARD_MERGE&#xFF1A;&#x5C06;&#x5404;&#x4E2A;&#x5206;&#x7247;&#x8FD4;&#x56DE;&#x6570;&#x636E;&#x8FDB;&#x884C;merge</li>
<li>SORT&#xFF1A;&#x8868;&#x660E;&#x5728;&#x5185;&#x5B58;&#x4E2D;&#x8FDB;&#x884C;&#x4E86;&#x6392;&#x5E8F;</li>
<li>LIMIT&#xFF1A;&#x4F7F;&#x7528;limit&#x9650;&#x5236;&#x8FD4;&#x56DE;&#x6570;</li>
<li>SKIP&#xFF1A;&#x4F7F;&#x7528;skip&#x8FDB;&#x884C;&#x8DF3;&#x8FC7;</li>
<li>IDHACK&#xFF1A;&#x9488;&#x5BF9;_id&#x8FDB;&#x884C;&#x67E5;&#x8BE2;</li>
<li>SHARDING_FILTER&#xFF1A;&#x901A;&#x8FC7;mongos&#x5BF9;&#x5206;&#x7247;&#x6570;&#x636E;&#x8FDB;&#x884C;&#x67E5;&#x8BE2;</li>
<li>COUNT&#xFF1A;&#x5229;&#x7528;db.coll.explain().count()&#x4E4B;&#x7C7B;&#x8FDB;&#x884C;count&#x8FD0;&#x7B97;</li>
<li>COUNTSCAN&#xFF1A;count&#x4E0D;&#x4F7F;&#x7528;Index&#x8FDB;&#x884C;count&#x65F6;&#x7684;stage&#x8FD4;&#x56DE;</li>
<li>COUNT_SCAN&#xFF1A;count&#x4F7F;&#x7528;&#x4E86;Index&#x8FDB;&#x884C;count&#x65F6;&#x7684;stage&#x8FD4;&#x56DE;</li>
<li>SUBPLA&#xFF1A;&#x672A;&#x4F7F;&#x7528;&#x5230;&#x7D22;&#x5F15;&#x7684;$or&#x67E5;&#x8BE2;&#x7684;stage&#x8FD4;&#x56DE;</li>
<li>TEXT&#xFF1A;&#x4F7F;&#x7528;&#x5168;&#x6587;&#x7D22;&#x5F15;&#x8FDB;&#x884C;&#x67E5;&#x8BE2;&#x65F6;&#x5019;&#x7684;stage&#x8FD4;&#x56DE;</li>
<li>PROJECTION&#xFF1A;&#x9650;&#x5B9A;&#x8FD4;&#x56DE;&#x5B57;&#x6BB5;&#x65F6;&#x5019;stage&#x7684;&#x8FD4;&#x56DE;</li>
<li><p>&#x5BF9;&#x4E8E;&#x666E;&#x901A;&#x67E5;&#x8BE2;&#xFF0C;&#x6211;&#x5E0C;&#x671B;&#x770B;&#x5230;stage&#x7684;&#x7EC4;&#x5408;(&#x67E5;&#x8BE2;&#x7684;&#x65F6;&#x5019;&#x5C3D;&#x53EF;&#x80FD;&#x7528;&#x4E0A;&#x7D22;&#x5F15;)&#xFF1A;</p>
<ul>
<li>Fetch+IDHACK</li>
<li>Fetch+ixscan</li>
<li>Limit+&#xFF08;Fetch+ixscan&#xFF09;</li>
<li>PROJECTION+ixscan</li>
<li>SHARDING_FITER+ixscan</li>
<li>COUNT_SCAN</li>
</ul>
</li>
<li><p>&#x4E0D;&#x5E0C;&#x671B;&#x770B;&#x5230;&#x5305;&#x542B;&#x5982;&#x4E0B;&#x7684;stage&#xFF1A;</p>
<ul>
<li>COLLSCAN(&#x5168;&#x8868;&#x626B;&#x63CF;),SORT(&#x4F7F;&#x7528;sort&#x4F46;&#x662F;&#x65E0;index),&#x4E0D;&#x5408;&#x7406;&#x7684;SKIP,SUBPLA(&#x672A;&#x7528;&#x5230;index&#x7684;$or),COUNTSCAN(&#x4E0D;&#x4F7F;&#x7528;index&#x8FDB;&#x884C;count)</li>
</ul>
</li>
</ul>

        <div class="copyright">Powered by <a href="https://github.com/jaywcjlove/idoc" target="_blank">idoc</a>. Dependence <a href="https://nodejs.org">Node.js</a> run.</div>
    </div>
    
</div>

<script src="https://cdn.bootcss.com/jquery/3.0.0/jquery.js"></script>
<script>
$('.warpper .page-toc ul ul li a').on('click',function(){
  $('.warpper .page-toc ul ul li a').removeClass('my-active')
  $(this).addClass('my-active')
})
  // if (!$('.understand-me').length) {
  //   var bar = $(window).height() - $('.navbar ').height() - $('.page-toc').position().top;
  //   var count = bar / 26 / 2;
  //   var barHeight = $('.page-toc').outerHeight();
  //   $('.page-toc li').eq(0).children('a').addClass('red');
  //   var arr = [];
  //   $("h1,h2,h3,h4,h5,h6").each(function () {
  //     arr.push($(this).position().top);
  //   });
  //   var timer
  //   function dark() {
  //     clearTimeout(timer)
  //      timer = setTimeout(function () {
  //      var top = Math.abs($('.page-toc > ul').position().top);
  //      var cur = $('.content').scrollTop();
  //      for (var i = arr.length; i >= 0; i--) {
  //        if (arr[i] <= cur) {
  //          break;
  //        }
  //      }
  //      if (i === -1) {
  //        i = 0;
  //      }
  //      $('.page-toc li a').removeClass('red');
  //      $('.page-toc li').eq(i).children('a').addClass('red');
  //      let height = $('.page-toc li').eq(i).position().top-$('.page-toc').height(); // 如果当前的offset出去了 回到中间可好？
  //      $('.page-toc').scrollTop(height+$('.page-toc').height()/2);
  //    },200)
  //   }

  //   $('.content').on('scroll', dark);
  // }
</script>
<style>

    /* ::-webkit-scrollbar{width:14px;}
    ::-webkit-scrollbar-track{background-color:transparent;}
    ::-webkit-scrollbar-thumb{background-color:transparent;}
    ::-webkit-scrollbar-thumb:hover {background-color:transparent}
    ::-webkit-scrollbar-thumb:active {background-color:transparent} */

    .page-toc > ul .red {
        background: #f3f3f3;
        z-index: 1;
        border-left: 3px solid #009a61;
        -webkit-transition: all .2s ease;
        transition: all .2s ease;
        color: #000
    }





</style>
</body>
</html>
